import babelpolyfill from 'babel-polyfill'
import Vue from 'vue'
import App from './App'
import ElementUI, {Message} from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
//import './assets/theme/theme-green/index.css'
import VueRouter from 'vue-router'
import store from './vuex/store'
import Vuex from 'vuex'

//import NProgress from 'nprogress'
//import 'nprogress/nprogress.css'
import routes from './routes'
/*import Mock from './mock'
Mock.bootstrap();*/
import 'font-awesome/css/font-awesome.min.css'
import '@/common/js/permission'


// 引入百度地图
import BaiduMap from 'vue-baidu-map'

Vue.use(BaiduMap, {
  /* Visit http://lbsyun.baidu.com/apiconsole/key for details about app key. */
  ak: 'EoTe0VwZe1Wu9sbGAA8LLSnAr3uc5AM1'
})



Vue.use(ElementUI)
Vue.use(VueRouter)
Vue.use(Vuex)
import axios from 'axios'
axios.defaults.baseURL='http://localhost:8080/'
Vue.prototype.$http = axios
//NProgress.configure({ showSpinner: false });

const router = new VueRouter({
  routes
})

//======================axios的前置拦截器：每次发送axios请求之前都要执行这个代码====================//
axios.interceptors.request.use(res=>{
  //从localStorage中获取token
  let token = localStorage.getItem("token");
  if(token){
    //将token设置到请求头：key：value = token：3a394c8f-9df0-49b5-8546-0bcaece33761
    res.headers["token"] = token;
  }
  return res;
},error => {
  Promise.reject(error)
})
//======================axios的前置拦截器【拦截调用后端的请求】====================//

//======================axios的后置拦截器【处理后台登录拦截的结果json数据】====================//
axios.interceptors.response.use(res => {
  //后端响应的是没有登录的信息
  if (false === res.data.success && "noLogin" === res.data.message) {
    //30分钟过期是redis过期，但是前端本地存储还在
    localStorage.removeItem("token");
    localStorage.removeItem("logininfo");
    localStorage.removeItem("permissions");
    localStorage.removeItem("menus");
    //调转到登录页面
    router.push({path: '/login'});
  }else if(false === res.data.success && "noPermission" === res.data.message){
    Message({"message":"你没有权限访问改资源!!!","type":"error"})
  }else if(false === res.data.success && "timeOut" === res.data.message){
    Message({"message":"过期了!!!","type":"error"})
    router.push({path: '/login'});
  }

  return res;
},error => {
  Promise.reject(error)
})

//======================axios的后置拦截器【处理后台登录拦截的结果】====================//
router.beforeEach((to, from, next) => {
  //如果访问登录页面   或  注册页面
  if (to.path == '/login' || to.path == "/register") {
    next();//放行
  }else{//其他页面都需要判断你是否登录过
    //获取localStorage的登录信息
    let logininfo = localStorage.getItem('logininfo');
    if (logininfo) {
      next(); //登录过放行
    } else {
      next({path: '/login'});//跳转到login - 登录页面
    }
  }
})


//处理页面刷新动态路由失效问题
initIndexRouters();
function initIndexRouters(){
  if(!localStorage.menus){
    return;
  }
  //防止重复配置路由：5就是main.js中路由的个数 - 如果你的静态路由是6个这里要写成6
  if(router.options.routes.length>5){
    return;
  }
  let menus = localStorage.getItem('menus');
  menus = JSON.parse(menus);
  let tempRouters = [];
  menus.forEach(menu=>{
    let indexRouter = {
      path: '/',
      iconCls: menu.icon,
      name: menu.name,
      component: resolve => require(['@/views/Home'], resolve),
      children: []
    }
    menu.children.forEach(cMenu=>{
      let cr = {
        path: cMenu.url,
        name: cMenu.name,
        component: resolve => require(['@/views/'+cMenu.component], resolve)
      }
      indexRouter.children.push(cr)
    })
    tempRouters.push(indexRouter)
    router.options.routes.push(indexRouter)
  })
  //动态路由配置
  router.addRoutes(tempRouters);
}

//router.afterEach(transition => {
//NProgress.done();
//});

new Vue({
  //el: '#app',
  //template: '<App/>',
  router,
  store,
  //components: { App }
  render: h => h(App)
}).$mount('#app')

